import * as React from "react"

import { ny } from "~/lib/utils"

const Card = React.forwardRef<
   HTMLDivElement,
   React.HTMLAttributes<HTMLDivElement>
>(({ className, ...props }, ref) => (
   <div
      ref={ref}
      className={ny(
         "bg-card text-card-foreground rounded-xl border shadow",
         className,
      )}
      {...props}
   />
))
Card.displayName = "Card"

const CardHeader = React.forwardRef<
   HTMLDivElement,
   React.HTMLAttributes<HTMLDivElement>
>(({ className, ...props }, ref) => (
   <div
      ref={ref}
      className={ny("flex flex-col space-y-1.5 p-6", className)}
      {...props}
   />
))
CardHeader.displayName = "CardHeader"

const CardTitle = React.forwardRef<
   HTMLParagraphElement,
   React.HTMLAttributes<HTMLHeadingElement>
>(({ className, ...props }, ref) => (
   <h3
      ref={ref}
      className={ny("font-semibold leading-none tracking-tight", className)}
      {...props}
   />
))
CardTitle.displayName = "CardTitle"

const CardDescription = React.forwardRef<
   HTMLParagraphElement,
   React.HTMLAttributes<HTMLParagraphElement>
>(({ className, ...props }, ref) => (
   <p
      ref={ref}
      className={ny("text-muted-foreground text-sm", className)}
      {...props}
   />
))
CardDescription.displayName = "CardDescription"

const CardContent = React.forwardRef<
   HTMLDivElement,
   React.HTMLAttributes<HTMLDivElement>
>(({ className, ...props }, ref) => (
   <div ref={ref} className={ny("p-6 pt-0", className)} {...props} />
))
CardContent.displayName = "CardContent"

const CardFooter = React.forwardRef<
   HTMLDivElement,
   React.HTMLAttributes<HTMLDivElement>
>(({ className, ...props }, ref) => (
   <div
      ref={ref}
      className={ny("flex items-center p-6 pt-0", className)}
      {...props}
   />
))
CardFooter.displayName = "CardFooter"

export { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent }
